linux输出的重定向无效问题和解决 您所在的位置:网站首页 linux 控制台输出重定向 linux输出的重定向无效问题和解决

linux输出的重定向无效问题和解决

#linux输出的重定向无效问题和解决| 来源: 网络整理| 查看: 265

我们在调试程序或者打印日志时经常会遇到重定向的问题,而有时候会遇到重定向无效的问题,下面给一个简单的例子,首先写一个简单的test.c

#include int main(){ fprintf(stdout, "hello\n"); fprintf(stderr, "world\n"); return 0; }

编译生成可执行程序test,如果执行:

./test > log.txt

会有打印

world

而hello的内容会跑到log.txt里面,同样如果我们写个脚本运行:

output=`./test` echo "*************************" echo $output

打印结果如下:

world ************************* hello

可以看到,hello跑到了output变量里面,而world没有,这是什么原因呢,显然关键在stdout和stderr。在linux系统,一旦创建一个进程,那么与之对应的会有三个数据流:stdin,stdout和stderr,对应的会创建三个文件:stdin,标准输入文件,通常对应着终端的键盘。stdout,标准输出文件,通常对应着终端的屏幕。stderr,标准错误输出文件,通常对应着终端的屏幕。 默认情况下,三个数据流对应的文件描述符分别是stdin—0,stdout—1,stderr—2,可通过代码查看:

#include #include int main() { int stdinFd = fileno(stdin); int stdoutFd = fileno(stdout); int stderrFd = fileno(stderr); std::cout


【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有